EzyPayment - as a Service (EPaaS)

(0 reviews)

API Spec Summary

API version : v1

EzyPayment host : https://stagingapp.sgebiz.com

EzyPayment BASE URL : {ezypayment_host}/x-ex-payment/api

API IDAPI NameAPI ResourceSecurityCalling PartyReceiving Party
API_R01Initiate Payment Redirection{ezypayment_base_url}/init/payment/redirectionPGP Signature parameterExternal PartyEzyPayment
API_R02Payment Response Redirection{redirect url from external party}PGP Signature parameterEzyPaymentExternal Party
API_B01Payment Response Callback{external party base url from registration}/status/paymentPGP signed and encrypted payloadEzyPaymentEzternal Party
API_B02Get Payment Status{ezypayment_base_url}/status/paymentPGP signed and encrypted payloadExternal PartyEzyPayment
API_B03Remittance Response Callback{external party base url from registration}/status/remittancePGP signed and encrypted payloadEzyPaymentEzternal Party
API_B04Get Remittance Status{ezypayment_base_url}/status/remittancePGP signed and encrypted payloadExternal PartyEzyPayment

API_R01 : Initiate Payment Redirection

External party can initiate this redirection once customer click on pay. The API should call as a browser location or a web location instead of a GET rest API call, since this will open the EzyPayment payment page.

URLhttps://{ezypayment_host}/x-ex-payment/api/{version}/init/payment/redirection
DescriptionRedirects the user from the External Party application to EzyPayment payment page.
HTTP MethodGET
Content typeN/A
Authenticationclient id enforcement
SecuritySecured with PGP signature in the query parameters.
Calling partyExternal Party
Request : Headers

N/A

Request : Query Parameters
AttributeDescriptionData typeMandatoryExample
client_idIssued client id of the external party.String (max = 36 chars)Yabcd1234EfgH4398
client_secretIssued client secret of the external party.String (max = 36 chars)Yxyz999-Abcirkls9827-kjsf8
customer-nameName of the customer, for reporting purpose.String (max = 250 chars)YJack Sparrow
customer-mobilePhone number of the customer, for reporting purpose.String (max = 20 chars)N+6587654321
customer-emailEmail of the customer, for reporting purpose.String (max = 250 chars)Yabcuser@mail.com
customer-refUnique reference to identify the customer.String (max = 36 chars)YU1237658
invoice-amountInvoice amount in SGD for the payment.Double (10, 2)Y12345678.12
invoice-refUnique reference number for the payment. This should be unique throughout all the payments done by the external party.String (max = 250 chars)YINV1234
invoice-descriptionDescription of the invoice. This will be shown to customer on the payment page.String (max = 250 chars)NRental for month of May to be paid by Jack. No parley allowed.
purposePurpose of the payment. Must be one of accepted purposes. See Appendix for the list of purposes.String (max = 50 chars)N
If not provided default will be taken from the Master purpose of external party.
Rent
redirect-back-urlWeb URL of the page which should user redirect once the payment completed. Note that both success and failed completions will be redirect to this, with status attached. The URL should not have any query parameters.String (max = 250 chars)Yhttps://mypage.com/payment-result
timestampRequest timestamp in EPOC millisecondsString (max = 15 chars)Y1604536682681
signatureQuery parameters (as a Json string) should be signed with external party PGP private key and attach as the last query param. This will be used for verifying the request and prevent data manipulation.
See Appendix on how to generate signature.
StringY----BEGIN+PGP+SIGNATURE %0AVersion%3A+Didisoft+OpenPGP+Library+for+Java3.2%0A%0AiAAAAwUAYI vJx2sHx69l4WlKAQ {...} Ldqgf%2Yt2EkqXoqGqRPogFWFdZ6X2ise5jO%2BAm END+PGP+SIGNATURE ----%0Ai
Request : Body

N/A

Responses
  • 302
Headerslocation : {EzyPayment payment page URL}
Query paramsN/A
BodyN/A

API_R02 : Payment Response Redirection

Once user completed the payment flow (either success or failed), the user will be redirect back to the URL given in API_R01 with additional query params for status. It is up to the external party to set up this URL as a front-end URL or a backend GET URL.

URLhttps://{external_party_redirect_url_from_API_R01}
DescriptionRedirects the user from the EzyPayment to External Party application.
HTTP MethodGET
Content typeN/A
AuthenticationN/A
SecuritySecured with PGP signature in the query parameters.
Calling partyEzyPayment
Request : Headers

N/A

Request : Query Parameters
AttributeDescriptionData typeMandatoryExample
statusStatus of the payment transactionString enum [SUCCESS, FAILED]YSUCCESS
error-codeError code of the error in case of an error occurred at the payment.
See Appendix for the list of error codes.
String (max = 6 chars)NEP4000
error-messageError message of the error in case of an error occurred at the payment.
See Appendix for the list of error messages.
String (max = 250 chars)NInsufficient funds
timestampRequest timestamp in EPOC millisecondsString (max = 15 chars)Y1604536682681
signatureQuery parameters (as a Json string) should be signed with EzyPayment PGP private key and attach as the last query param. This will be used for verifying the request and prevent data manipulation.
See Appendix on how to verify signature.
StringY----BEGIN+PGP+SIGNATURE %0AVersion%3A+Didisoft+OpenPGP+Library+for+Java3.2%0A%0AiAAAAwUAYI vJx2sHx69l4WlKAQ {...} Ldqgf%2Yt2EkqXoqGqRPogFWFdZ6X2ise5jO%2BAm END+PGP+SIGNATURE ----%0Ai
Request : Body

N/A

Responses
  • It is up to the external party to handle the API.

API_B01 : Payment Response Callback

Once user completed the payment flow (either success or failed), the payment status will be pushed to External Party backend API. It is up to the external party to set up this URL as a backend POST API and handle the processing/storing the data.

URLhttps://{external_party_BASE_URL_from_registration}/status/payment
DescriptionSends payment status from EzyPayment to External Party backend.
HTTP MethodPOST
Content typeapplication/json
SecuritySecured with PGP sign and encryption in request body.
Calling partyEzyPayment
Request : Query Parameters

N/A

Request : Body

Request body is a PGP signed/encrypted payload as a string as follows.

"-----BEGIN PGP MESSAGE----- Version: Didisoft OpenPGP Library for Java 3.2 hQEMA63UlgaQT+XfAQgAjYasSxqx9dPiXK48dmylIWWvbKmt0PZ+ESz57akDEHHy ... BzubwsgqffLbaQ/bIuP7Hy+fhZs0LGN6aNz8vjyHRfqMxhtfQP2qxwZLWlHrqwwE WnKJye+bNAoemQUvaqxgrlmCM5l6InuLVQhQfk3Ppu2I =rDE6 -----END PGP MESSAGE-----"

The encrypted data contains below fields.

AttributeDescriptionData typeMandatoryExample
customerRefSame as API_R01.String (max = 36 chars)YU1237658
invoiceAmountSame as API_R01.Double (10, 2)Y12345678.12
invoiceRefSame as API_R01.String (max = 250 chars)YINV1234
statusStatus of the payment transactionString enum [SUCCESS, FAILED]YSUCCESS
transactionIdAuto generated unique payment transaction idString (max = 50 chars)Y2398790834kjfi39
errorCodeError code of the error in case of an error occurred at the payment.
See Appendix for the list of error codes.
String (max = 6 chars)NEP4000
errorMessageError message of the error in case of an error occurred at the payment.
See Appendix for the list of error messages.
String (max = 250 chars)NInsufficient funds
timestampRequest timestamp in EPOC millisecondsString (max = 15 chars)Y1604536682681
Responses
  • 200

It is up to the external party to handle the API.

EzyPayment will expect the following response from external party to confirm that the data are accepted. Note that the response always should be in http status 200.

HeadersN/A
Query paramsN/A
Content-typeapplication/json
EncryptionNot needed

Response Body

AttributeDescriptionData typeMandatoryExample
statusWhether accepted or notString enum [OK, REJECTED]YOK
reasonIf the status is rejected then the reject reasonString (max = 255 chars)NCannot verify the payload

Response Body Example

{
  "status": "OK"
}

API_B02 : Get Payment Status

External party can call this API anytime to get details of payment transactions.

URLhttps://{ezypayment_base_url}/status/payment
DescriptionExternal party request payment status from EzyPayment.
HTTP MethodGET
Content typeapplication/json
Authenticationclient id enforcement
SecuritySecured with PGP sign and encryption in response body.
Calling partyExternal Party
Request : Headers
headervaluerequired
client_idclient id given in the registrationY
client_secretclient secret given in the registrationY
timestampRequest timestamp in EPOC millisecondsY
Request : Query Parameters
AttributeDescriptionData typeMandatoryExample
invoice-refA list of invoice ref numbersArray of String (max = 250 chars)NINV1234,INV3453
from-dateIf need to filter by the datesDatetime in format (yyyy-MM-dd'T'hh:mm:ss'Z')N2023-01-01T00:00:00Z
to-dateIf need to filter by the datesDatetime in format (yyyy-MM-dd'T'hh:mm:ss'Z')N2023-01-01T00:00:00Z
Request : Body

N/A

Responses
  • 200

Response body is a PGP signed/encrypted payload as a string as follows.

"-----BEGIN PGP MESSAGE----- Version: Didisoft OpenPGP Library for Java 3.2 hQEMA63UlgaQT+XfAQgAjYasSxqx9dPiXK48dmylIWWvbKmt0PZ+ESz57akDEHHy ... BzubwsgqffLbaQ/bIuP7Hy+fhZs0LGN6aNz8vjyHRfqMxhtfQP2qxwZLWlHrqwwE WnKJye+bNAoemQUvaqxgrlmCM5l6InuLVQhQfk3Ppu2I =rDE6 -----END PGP MESSAGE-----"

The encrypted data contains below fields as Array of objects per invoice-ref in the request.

AttributeDescriptionData typeMandatoryExample
customerRefSame as API_R01.String (max = 36 chars)YU1237658
invoiceAmountSame as API_R01.Double (10, 2)Y12345678.12
invoiceRefSame as API_R01.String (max = 250 chars)YINV1234
statusStatus of the payment transactionString enum [SUCCESS, FAILED]YSUCCESS
transactionIdAuto generated unique payment transaction idString (max = 50 chars)Y2398790834kjfi39
errorCodeError code of the error in case of an error occurred at the payment.
See Appendix for the list of error codes.
String (max = 6 chars)NEP4000
errorMessageError message of the error in case of an error occurred at the payment.
See Appendix for the list of error messages.
String (max = 250 chars)NInsufficient funds
timestampRequest timestamp in EPOC millisecondsString (max = 15 chars)Y1604536682681

API_B03 : Remittance Response Callback

Once the remittance has been done (either success or failed), the remittance status will be pushed to External Party backend API. It is up to the external party to set up this URL as a backend POST API and handle the processing/storing the data.

Note that the remittances may contain multiple payment transactions in some conditions. With the remittance status API will return the list of payments that it belongs to.

URLhttps://{external_party_BASE_URL_from_registration}/status/remittance
DescriptionSends remittance status from EzyPayment to External Party backend.
HTTP MethodPOST
Content typeapplication/json
SecuritySecured with PGP sign and encryption in request body.
Calling partyEzyPayment
Request : Query Parameters

N/A

Request : Body

Request body is a PGP signed/encrypted payload as a string as follows.

"-----BEGIN PGP MESSAGE----- Version: Didisoft OpenPGP Library for Java 3.2 hQEMA63UlgaQT+XfAQgAjYasSxqx9dPiXK48dmylIWWvbKmt0PZ+ESz57akDEHHy ... BzubwsgqffLbaQ/bIuP7Hy+fhZs0LGN6aNz8vjyHRfqMxhtfQP2qxwZLWlHrqwwE WnKJye+bNAoemQUvaqxgrlmCM5l6InuLVQhQfk3Ppu2I =rDE6 -----END PGP MESSAGE-----"

The encrypted data contains below fields.

AttributeDescriptionData typeMandatoryExample
remittanceIdAuto generated remittance transaction idString (max = 20 chars)Yabcd000092384
remittanceRefAuto generated remittance referenceString (max = 15 chars)Ybulk-payment
remittanceAmountCombined remittance amountDouble (10, 2)Y12345678.12
statusStatus of the remittance transactionString enum [SUCCESS, FAILED]YSUCCESS
errorCodeCode of the error, in case of an error occurred at the remittance.
See Appendix for the list of error codes.
String (max = 6 chars)NEP4000
errorMessageMessage of the error, in case of an error occurred at the remittance.
See Appendix for the list of error messages.
String (max = 250 chars)NInvalid account number
timestampRequest timestamp in EPOC millisecondsString (max = 15 chars)Y1604536682681
paymentsList of payments that relate to this remittanceArry of ObjectsY...
payments.invoiceRefPayment invoice referenceString (max = 250 chars)YINV1234
payments.transactionIdPayment transaction idString (max = 50 chars)Y2398790834kjfi39
Responses
  • 200

It is up to the external party to handle the API.

EzyPayment will expect the following response from external party to confirm that the data are accepted. Note that the response always should be in http status 200.

HeadersN/A
Query paramsN/A
Content-typeapplication/json
EncryptionNot needed

Response Body

AttributeDescriptionData typeMandatoryExample
statusWhether accepted or notString enum [OK, REJECTED]YOK
reasonIf the status is rejected then the reject reasonString (max = 255 chars)NCannot verify the payload

Response Body Example

{
  "status": "OK"
}

API_B04 : Get Remittance Status

External party can call this API anytime to get details of remittance transactions.

URLhttps://{ezypayment_base_url}/status/remittance
DescriptionExternal party request remittance status from EzyPayment.
HTTP MethodGET
Content typeapplication/json
Authenticationclient id enforcement
SecuritySecured with PGP sign and encryption in response body.
Calling partyExternal Party
Request : Headers
headervaluerequired
client_idclient id given in the registrationY
client_secretclient secret given in the registrationY
timestampRequest timestamp in EPOC millisecondsY
Request : Query Parameters
AttributeDescriptionData typeMandatoryExample
invoice-refA list of invoice ref numbersArray of String (max = 250 chars)NINV1234,INV3453
from-dateIf need to filter by the datesDatetime in format (yyyy-MM-dd'T'hh:mm:ss'Z')N2023-01-01T00:00:00Z
to-dateIf need to filter by the datesDatetime in format (yyyy-MM-dd'T'hh:mm:ss'Z')N2023-01-01T00:00:00Z
Request : Body

N/A

Responses
  • 200

Response body is a PGP signed/encrypted payload as a string as follows.

"-----BEGIN PGP MESSAGE----- Version: Didisoft OpenPGP Library for Java 3.2 hQEMA63UlgaQT+XfAQgAjYasSxqx9dPiXK48dmylIWWvbKmt0PZ+ESz57akDEHHy ... BzubwsgqffLbaQ/bIuP7Hy+fhZs0LGN6aNz8vjyHRfqMxhtfQP2qxwZLWlHrqwwE WnKJye+bNAoemQUvaqxgrlmCM5l6InuLVQhQfk3Ppu2I =rDE6 -----END PGP MESSAGE-----"

The encrypted data contains below fields as Array of objects per remittance matching to invoice-ref in the request.

AttributeDescriptionData typeMandatoryExample
remittanceIdAuto generated remittance transaction idString (max = 20 chars)Yabcd000092384
remittanceRefAuto generated remittance referenceString (max = 15 chars)Ybulk-payment
remittanceAmountCombined remittance amountDouble (10, 2)Y12345678.12
statusStatus of the remittance transactionString enum [SUCCESS, FAILED]YSUCCESS
errorCodeCode of the error, in case of an error occurred at the remittance.
See Appendix for the list of error codes.
String (max = 6 chars)NEP4000
errorMessageMessage of the error, in case of an error occurred at the remittance.
See Appendix for the list of error messages.
String (max = 250 chars)NInvalid account number
timestampRequest timestamp in EPOC millisecondsString (max = 15 chars)Y1604536682681
paymentsList of payments that relate to this remittanceArry of ObjectsY...
payments.invoiceRefPayment invoice referenceString (max = 250 chars)YINV1234
payments.transactionIdPayment transaction idString (max = 50 chars)Y2398790834kjfi39

Reviews